home *** CD-ROM | disk | FTP | other *** search
/ Language/OS - Multiplatform Resource Library / LANGUAGE OS.iso / prolog / ai.prl / opnprlg1.hqx / Open Prolog / Documents / Open Prolog Extras < prev    next >
Text File  |  1993-04-15  |  14KB  |  286 lines

  1. Ñ Open Prolog Extras
  2. Some of the useful external predicates in Open Prolog 1.0d42 are listed below.
  3. Check for the existence of these predicates as described in Open Prolog Info -
  4. it's always possible for the documentation to be out of date.
  5. Mail us if you see something you can't understand or use - that way,
  6. we might fix the documentation╔
  7.  
  8. Ñ Menus
  9. ╫ Adding & Manipulating Menus
  10. To add a menu, or to change an existing menu, use the following call:
  11.  
  12. 'system$menu'(set,MenuName,MenuItemName,Kind,Enable,
  13.                         Icon,KeyEquivalent,MarkChar,MenuNumber,ItemNumber).
  14.  
  15. %a MenuItemName of '' will not add anything to the list of the menu's items, but will add the menu to the list of menus if necessary.
  16. %always use 'set' or 'delete' for the first argument.
  17. %enter 'standard' or 'hierarchical' for the kind field.
  18. %Enter 'enabled'  or 'disabled' or '' in the Enable field.
  19. %Enter Icon Number or 0 in Icon Field
  20. %Enter character code for Keyboard Equivalent in KeyEquivalent Field (only works for a new menu).
  21. %Enter character code for Marking Character in MarkChar Field.
  22. %Menu Number & Item Number are returned.
  23.  
  24. 'system$menu' can be used to enable & disable existing menu items.
  25. The system adds 256 to the icon number you provide, if it's not 0.
  26. (Supply your own icons using something like ResEdit.)
  27. example:
  28.  
  29. J is "",K is "Y",'system$menu'(set,'Trixi','First Menu 2',standard,enabled,1,K,J,Menu,Item).
  30.  
  31. SUGGESTION - set the font for this window to Chicago (the standard menu bar font), and experiment with different values for J above (look in KeyCaps for reference - e.g. control-R gives the tick mark ).
  32. When the menu is selected by the user, Open Prolog looks for a clause
  33. with a head of the form:
  34. 'system$menu$hook'(MenuName,MenuItemName)
  35. If it is found, the clause is executed.
  36.  
  37. í Hierarchical Menus
  38. The Command Key field and the Mark Char field are re-used to implement hierarchical menus. To hook up hierarchical menus, the Markchar number of the menu item that points to the hierarchical menus must be the same as the hierarchical menu's Menunumber. So, you can define the hierarchical menu items first, getting back the menu's menunumber; then define the menu item that points to it as a hierarchical menu pointer (by making its command character number 27), and 'hook it up' to the previously defined hierarchical menu by defining its markchar number to be the same as the hierarchical menu's number. Complicated huh?
  39.  
  40. Notice that when a hierarchical menu item is selected, it is the *menu's* name and the menu item name that are returned - see the example below.
  41.  
  42. Here's an example that also demonstrates the 'system$menu$hook'. Select it all and press the ENTER key:
  43.  
  44. 'system$owner$name'(Y),(Y='',You='Oh Wise User';Y=You),
  45. 'system$menu'(set,'Greeting',You,hierarchical,enabled,0,0,0,MenuNumber,_),
  46. 'system$menu'(set,'Greeting','-',hierarchical,disabled,0,0,0,MenuNumber,_),
  47. 'system$menu'(set,'Greeting','Mike',hierarchical,enabled,0,0,0,MenuNumber,_),
  48. 'system$menu'(set,'Greeting','NùirÆn',hierarchical,enabled,0,0,0,MenuNumber,_),
  49. 'system$menu'(set,'Greeting','-',hierarchical,disabled,0,0,0,MenuNumber,_),
  50. 'system$menu'(set,'Greeting','Clare',hierarchical,enabled,0,0,0,MenuNumber,_),
  51. 'system$menu'(set,'Greeting','Katie',hierarchical,enabled,0,0,0,MenuNumber,_),
  52. 'system$menu'(set,'Greeting','Alison',hierarchical,enabled,0,0,0,MenuNumber,_),
  53. 'system$menu'(set,'Sample1','Example',standard,enabled,0,27,MenuNumber,Menu,Item),
  54. assert(('system$menu$hook'('Greeting',X) :- write('Hi '),write(X),nl)).
  55.  
  56. ╫ Deleting Menu Items & Menus
  57. 'system$menu'(delete,Menu,MenuItem,_,_,_,_,_,_,_).
  58.  
  59. If the MenuItem is '', the whole menu is deleted. Be careful about deleting the standard menus - they are linked to Open Prolog by position, not by text or appearance.
  60.  
  61. For some special purposes, you may wish to delete the Prolog menu; that's fine, but you'd also be deleting the command-(.) menu item which is used for stopping wayward program execution. You can redefine the command-(.) menu item to suit your own purposes, as long as you make sure its command key equivalent is the dot.
  62.  
  63. Ñ Status Bar
  64. The status bar is available to your program as a convenient display for the state of your program. Users are happier when they know something is happening. The rotating cursor indicates that Open Prolog is running, and you can get your program to display ongoing information on the status bar.
  65. There are three resources available to your program:
  66. (1) The status box at the extreme left - normally it contains the prompt ?-; occasionally it contains 'mm' or 'gc' indicating memory management or garbage collection activity.
  67. (2) The message box, from the right hand side of the window leftwards. This may contain a larger string of text.
  68. (3) The progress indicator. This is a 'thermometer' - a rectangle in which you can set the fraction of it showing gray. You see this when consulting a file.
  69.  
  70. You can push, set (i.e. change) or pull messages to or from the status and message boxes, and you can show, hide and set the progress indicator.
  71.  
  72. í Status & Message Stuff
  73.  
  74. Example:
  75. 'system$push$display'(message,center,'Hi',' ',there,' user'),
  76. 'system$delay$ticks'(100),
  77. 'system$pop$display'(message).
  78.  
  79. First argument: status or message
  80. Second argument: left, centre, center or right
  81. Third, Fourth, Fifth and Sixth Arguments: these will be concatenated and displayed.
  82.  
  83. Pushing a message hides the old message, so that when you pop the message, the old message reappears.
  84. Setting a message replaces the text of the old message, which cannot subsequently be recovered.
  85.  
  86. í Progress Indicator stuff
  87.  
  88. 'system$show$progress'. %display progress thermometer
  89. 'system$hide$progress'. %hide display thermometer
  90.  
  91. 'system$set$progress'(A,B).   % set gray part of thermometer as a fraction of the rectangle equal to the ratio A/B.
  92. Previous values of A and B are lost.
  93.  
  94. Note: if your application's execution is characterised by processing a file, then by using the 'system$get$file$size' and 'system$get$fpos' predicates (see below) in conjunction with the progress indicator, you can give the user an idea of how much progress is being made. Here is an example where calls to the get0 predicate could be replaced by get0WithProgress:
  95.  
  96. get0WithProgress(X) :-
  97.         seeing(user),!, %don't display for input from the user╔
  98.         get0(X).
  99. get0WithProgress(X) :-
  100.         seeing(File),
  101.         'system$get$file$size'(File,Size,0),
  102.         'system$get$fpos'(Pos),
  103.         'system$set$progress'(Pos,Size),
  104.         get0(X).
  105.  
  106.  
  107. Ñ Alerts and Confirmations
  108.  
  109. 'system$alert'(alertMessage1,alertMessage2,alertMessage3,alertMessage4).
  110. %must not be structured terms. They are concatenated & displayed.
  111.  
  112. 'system$confirm'(message1,message2,message3,message4).
  113. %must not be structured terms. They are concatenated & displayed.
  114. Succeeds or fails depending on Yes or No button.
  115.  
  116. Ñ Information
  117.  
  118. 'system$owner$name'(Name). % from Chooser or Sharing Setup. It used to be called
  119.                                                %'system$username'(X).
  120.  
  121. 'system$machine$name'(Name). %System 7 only - from Sharing Setup
  122.  
  123. 'system$machine$kind'(Name). %System 7 only - e.g. PowerBook 140.
  124.  
  125. 'system$show$about' %Shows the About Open Prolog╔ box
  126. 'system$hide$about' %Shows the About Open Prolog╔ box
  127.  
  128. 'toolbox$GetIndString'(Atom,ResourceNumber,Index). %same as the Mac
  129. Toolbox GetIndString, where the string is turned into an atom.
  130.  
  131. 'system$predicate'(Name,Term,Kind). %all normal, built-in and external predicates (see example in Open Prolog Info).
  132.  
  133. Ñ Time & Date
  134.  
  135. 'system$seconds'(Seconds). %Since 1/1/1904 - negative but don't worry. Use it for date and time, as shown below:
  136. 'system$date'(Seconds,Date). %Converts Seconds to Date
  137. 'system$time'(Seconds,Time). %Converts Seconds to Time
  138. 'system$delay$ticks'(Ticks). %stop execution for the specified number of Ticks - a tick is about 1/60th of a second.
  139.  
  140. Ñ Random Numbers
  141.  
  142. 'system$random'(Range,RandomNumber). %range is always input
  143. %range is from 0 to the predecessor of Range.
  144. If Range is positive, then the numbers will go from 0 to Range-1, inclusive.
  145. If Range is negative, then the numbers will go from 0 to Range+1, inclusive.
  146. It doesn't make sense to ask for random numbers in the range of -1, 0 or +1.
  147.  
  148. %use command-dot to exit from the following example:
  149. repeat,'system$random'(10,RandomNumber),write(RandomNumber),write(' '),fail. 
  150.  
  151. Ñ Sound
  152.  
  153. macintalk(Phrase,Volume).  %This will speak the text of the phrase, and needs MacinTalk to work. 
  154. The Phrase must be an atom or a number. 
  155. Pass a Volume of 0 - 7.  A volume of 0 means the current sound volume control setting
  156. will be used.
  157. Due to a bug in Macintalk, all other sounds are disabled!
  158. KidsTime¬ from Great Wave Software has a way of getting round this. If anyone knows how, please let us know.
  159.  
  160. eg. 
  161. 'system$owner$name'(X),macintalk('Hi',7),macintalk(X,7).
  162.  
  163. play(SoundName,Volume) will play any Type 1 'snd ' resource.
  164. Sounds recorded with the new ╘Sound╒ Control Panel Device and 
  165. all the sounds for the System Bell are snds of this type.
  166. To play them, give their names exactly as they appear in
  167. the ╘Sound╒ Control Panel Device.
  168. Be careful to get spacing and punctuation exactly right.
  169. If the sound can't be found, or is too big to fit into memory,
  170. the call will fail,
  171. Pass a Volume of 0 - 7.  A volume of 0 means the current sound volume control setting
  172. will be used.
  173.  
  174. E.g.
  175. play('Simple Beep',5).
  176.  
  177. The snd resources can be resident in any open window, the Worksheet,
  178. Open Prolog itself, or the System.
  179.  
  180. Ñ Low Level Debug
  181.  
  182. macsbug & macsbugFail need Macsbug to work, and will crash otherwise.
  183.  
  184. Ñ File Stuff
  185.  
  186. 'system$get$file$size'(FileName,FileSize,ErrorNumber).
  187. %returns in FileSize the size of FileName in bytes. (Normally one character occupies one byte.) An ErrorNumber of 0 is OK, anything else is a problem. Note that it isn't necessarily possible to open the file.
  188. e.g.
  189. 'system$get$file$size'('Open Prolog Info',FileSize,ErrorNumber).
  190.  
  191. 'system$get$fpos'(Fpos).
  192.  
  193. %returns the ordinate (that is, the position in the file, starting at 0) of the next character to be read from the current input file.
  194.  
  195. 'open$prolog$eof$char'(CurrentEofChar,NewEofChar). %default is 26
  196. 'open$prolog$eoln$char'(CurrentEolnChar,NewEolnChar). %default 31
  197. These are the characters returned by get or get0 for an end-of-line condition of an end-of-file condition, chosen for compatibility with DEC10 Prolog.
  198.  
  199. Ñ Window-handling Predicates.
  200.  
  201. A number of predicates have been written to handle window-based I/O.
  202. Please be aware that they are subject to change.
  203.  
  204. Basic Ideas:
  205. í    Window Numbers
  206. We use window numbers because it is not possible to refer to a window by its name. This is because its name may change, and because (in theory anyway) many windows could have the same names.
  207. So, every window is assigned a window number when it is created (distinct from its parameter pointer or file number etc.). 
  208.  
  209. í    Starting Pointer & Single-Line-Selection
  210. Whenever text is output to a window (say using the write command), a pointer, called the Starting Pointer, is made point to the next character after the last
  211. character output.
  212.  
  213. When a user selects text using the ENTER key, the text selected goes
  214. into a text buffer that is passed to the Prolog interpreter.
  215. In the case of single-line-selection, the start of the selection is found by going from the caret backwards along the line to the start of the line or to the Starting Pointer, whichever comes first. The end of the selection is the end of the line. 
  216.  
  217. í Highlighting & Outlines
  218. It is possible to highlight a particular run of text. Just to confuse you,
  219. the highlight is called an outline, because that's how it started out.
  220. The highlight will 'stick' to the text specified even when text before,
  221. within or after it has been added or removed. Therefore it's not safe to
  222. refer to a highlight by its start & end points, which may vary. Instead, a
  223. highlight is given a unique index number by which it may be referred to
  224. later.
  225.  
  226. ╫    Some Built-Ins
  227.  
  228. 'system$window$open$file$window'(Name,WindowNumber,ResultCode)
  229. A window is opened with the name given (or brought to the front if it's
  230. open already). A file of the same name must exist, and it's opened into the
  231. window. A result code of 0 indicates everything was OK;
  232. anything else means some error occured. Standard Macintosh
  233. error codes are used.
  234.  
  235. 'system$window$open$new$window'(Name,WindowNumber,ResultCode)
  236. A window is opened with the name given (or brought to the front if it's
  237. open already).
  238. No connection is made with a file of the same name even if it exists.
  239.  
  240. 'system$window$set$starting$point'(WindowNumber,StartingPoint) &
  241. 'system$window$get$starting$point'(WindowNumber,StartingPoint).
  242.  
  243. These can be used to get and set the starting point. Normally you needn't
  244. bother with these, as the starting point is automatically updated.
  245.  
  246. Sometimes, however, you 'll need them. For example, say you've written
  247. a parser, and you want to indicate errors to the user in the window.
  248. When you display the error message as appropriate, you'll want to
  249. reset the window environment just as it was just before
  250. the error occured. For this, you'll need to get the Starting Point beforehand,
  251. and then reset it after outputting the error message, etc.
  252. I have a rather complex example, so mail me if you'd like it.
  253.  
  254. 'system$window$front'(WindowNumber).
  255. Tells you which window is at the front.
  256.  
  257. 'system$window$get$output'(WindowNumber).
  258. Tells you which is the current output window.
  259.  
  260. 'system$window$set$output'(WindowNumber,Status).
  261. The designated window becomes the output window. Any error (e.g. if
  262. the window is read-only, etc. will be reported in Status. A Status of 0
  263. means OK.
  264.  
  265. 'system$window$select'(WindowNumber).
  266. Bring the window to the front.
  267.  
  268. 'system$window$get$selection'(WindowNumber,Start,End)
  269. Tells you the selection start and end.
  270.  
  271. 'system$window$set$selection'(WindowNumber,Start,End)
  272. Allows you to set the selection start and end.
  273.  
  274. 'system$window$set$outline'(WindowNumber,StyleNumber,
  275.             Start,End,OutlineReference).
  276. Only a style 1 is defined.
  277.  
  278. 'system$window$clear$outline'(WindowNumber,OutlineReference).
  279.  
  280. 'system$window$buffer$size'(WindowNumber,UnreadBytesLeftInSelection).
  281.  
  282. For example, to highlight the first 100 characters in this file:
  283.  
  284. 'system$window$front'(WindowNumber),
  285. 'system$window$set$outline'(WindowNumber,1,1,100,OutlineReference).
  286.